<template>
  <div class="app-container">
    <div class="filter-container">
      <el-input
        v-model="listQuery.formKey"
        placeholder="表单key"
        style="width: 200px"
        class="filter-item"
        size="small"
        @keyup.enter.native="btnQuery"
      />
      <el-input
        v-model="listQuery.formName"
        placeholder="表单名称"
        style="width: 200px"
        size="small"
        class="filter-item"
        @keyup.enter.native="btnQuery"
      />
      <el-dropdown
        split-button
        size="small"
        type="primary"
        @click="btnQuery"
        class="filter-item"
      >
        <i class="el-icon-search el-icon--left"></i>查询
        <el-dropdown-menu slot="dropdown">
          <el-dropdown-item icon="el-icon-zoom-out" @click.native="btnReset"
            >重置</el-dropdown-item
          >
        </el-dropdown-menu>
      </el-dropdown>
      <el-button-group style="margin-left:20px">
        <!-- v-permission="'flowable:form:save'" -->
        <el-button
          size="small"
          icon="el-icon-plus"
          type="primary"
          @click="btnCreate"
          class="filter-item"
          >新增
        </el-button>
        <!-- v-permission="'flowable:form:delete'" -->
        <el-button
          size="small"
          style="margin-left:20px"
          icon="el-icon-delete"
          @click="btnDelete()"
          class="filter-item"
          >批量删除
        </el-button>
      </el-button-group>
    </div>
    <el-table
      :data="records"
      ref="multipleTable"
      @selection-change="selectionChange"
      border
      fit
      highlight-current-row
      style="width: 100%"
      :cell-style="{ padding: '3px' }"
    >
      <el-table-column type="selection" align="center"> </el-table-column>
      <el-table-column label="表单key" prop="formKey" align="center">
        <template slot-scope="scope"
          ><span>{{ scope.row.formKey }}</span></template
        >
      </el-table-column>
      <el-table-column label="表单名称" prop="formName" align="center">
        <template slot-scope="scope"
          ><span>{{ scope.row.formName }}</span></template
        >
      </el-table-column>
      <el-table-column label="操作" align="center">
        <template slot-scope="{ row }">
          <el-dropdown>
            <span class="el-dropdown-link"
              >操作<i class="el-icon-arrow-down el-icon--right"></i
            ></span>
            <el-dropdown-menu slot="dropdown">
              <el-dropdown-item icon="el-icon-view" @click.native="btnView(row)"
                >查看</el-dropdown-item
              >
              <!-- v-permission="'flowable:form:update'" -->
              <el-dropdown-item
                icon="el-icon-edit"
                divided
                @click.native="btnUpdate(row)"
                >修改
              </el-dropdown-item>
              <!-- v-permission="'flowable:form:update'" -->
              <el-dropdown-item
                icon="el-icon-edit"
                divided
                @click.native="btnUpdateFormJson(row)"
                >修改表单
              </el-dropdown-item>
              <!-- v-permission="'flowable:form:delete'" -->
              <el-dropdown-item
                icon="el-icon-delete"
                divided
                @click.native="btnDelete(row.formKey)"
                >删除
              </el-dropdown-item>
            </el-dropdown-menu>
          </el-dropdown>
        </template>
      </el-table-column>
    </el-table>
    <pagination
      v-show="total > 0"
      :total="total"
      :current.sync="listQuery.current"
      :size.sync="listQuery.size"
      @pagination="list"
    />

    <el-dialog title="流程表单" :visible.sync="dialogFormVisible">
      <el-form
        ref="dataForm"
        :rules="rules"
        :model="temp"
        :disabled="dialogStatus === 'view'"
        label-position="right"
        label-width="110px"
      >
        <el-form-item label="表单key" prop="formKey">
          <el-input
            v-model="temp.formKey"
            :readonly="dialogStatus === 'update'"
          />
        </el-form-item>
        <el-form-item label="表单名称" prop="formName">
          <el-input v-model="temp.formName" />
        </el-form-item>
      </el-form>
      <div slot="footer" class="dialog-footer">
        <el-button icon="el-icon-close" @click="dialogFormVisible = false"
          >取消</el-button
        >
        <el-button
          v-if="dialogStatus !== 'view'"
          icon="el-icon-check"
          type="primary"
          @click="dialogStatus === 'create' ? createData() : updateData()"
          >确定
        </el-button>
      </div>
    </el-dialog>
  </div>
</template>

<script>
import Pagination from "@/components/DiyPagination";
import { deleteAction, getAction, postAction, putAction,getFormList } from "@/api/workordermanage";
import { Message } from "element-ui";

export default {
  name: "FlowableForm",
  components: { Pagination },
  data() {
    return {
      dicts: [],
      records: null,
      selectedRecords: [],
      total: 0,
      listQuery: {
        current: 1,
        size: 10,
        formKey: undefined,
        formName: undefined,
      },
      dialogFormVisible: false,
      dialogStatus: "",
      temp: {
        formKey: undefined,
        formName: "",
      },
      rules: {
        formKey: [
          { required: true, message: "该项不能为空", trigger: "change" },
        ],
        formName: [
          { required: true, message: "该项不能为空", trigger: "change" },
        ],
      },
    };
  },
  created() {
    this.list();
  },
  methods: {
    list() {
      getAction("/dev-api/asset-work-order/flowable/form/list", this.listQuery).then((res) => {
        const { data } = res.data;
        this.records = data.records;
        this.total = data.total;
      });
    },
    btnQuery() {
      this.listQuery.current = 1;
      this.list();
    },
    btnReset() {
      this.listQuery = {
        current: 1,
        size: 10,
        formKey: undefined,
        formName: undefined,
      };
      this.list();
    },
    resetTemp() {
      this.temp = {
        formKey: undefined,
        formName: "",
      };
    },
    btnView(row) {
      this.temp = Object.assign({}, row);
      this.dialogStatus = "view";
      this.dialogFormVisible = true;
      this.$nextTick(() => {
        this.$refs["dataForm"].clearValidate();
      });
    },
    btnCreate() {
      this.resetTemp();
      this.dialogStatus = "create";
      this.dialogFormVisible = true;
      this.$nextTick(() => {
        this.$refs["dataForm"].clearValidate();
      });
    },
    createData() {
      this.$refs["dataForm"].validate((valid) => {
        if (valid) {
          postAction("/dev-api/asset-work-order/flowable/form/save", this.temp).then(({ data }) => {
            this.dialogFormVisible = false;
            Message.success(data.msg);
            this.list();
          });
        }
      });
    },
    btnUpdate(row) {
      this.temp = Object.assign({}, row);
      this.dialogStatus = "update";
      this.dialogFormVisible = true;
      this.$nextTick(() => {
        this.$refs["dataForm"].clearValidate();
      });
    },
    btnUpdateFormJson(row) {
      this.$router.push({
        name: "workorder-form-edit",
        query: { formKey: row.formKey },
      });
    },
    updateData() {
      this.$refs["dataForm"].validate((valid) => {
        if (valid) {
          putAction("/dev-api/asset-work-order/flowable/form/update", this.temp).then(({ data }) => {
            this.dialogFormVisible = false;
            Message.success(data.msg);
            this.list();
          });
        }
      });
    },
    btnDelete(id) {
      let ids = id
        ? [id]
        : this.selectedRecords.map((record) => {
            return record.formKey;
          });
      if (ids.length == 0) {
        Message.error("请选择要删除的记录");
        return;
      }
      deleteAction("/dev-api/asset-work-order/flowable/form/delete", { ids: ids.toString() }).then(
        ({ data }) => {
          Message.success(data.msg);
          this.list();
        }
      );
    },
    selectionChange(selectedRecords) {
      this.selectedRecords = selectedRecords;
    },
  },
};
</script>
